// axios基础的封装
import axios from 'axios'
import { useUserStore } from '@/stores/userStore'
import {useRouter} from "vue-router";
const request = axios.create({
    baseURL: 'http://pcapi-xiaotuxian-front-devtest.itheima.net',
    timeout: 5000
})

// 拦截器

// axios请求拦截器
request.interceptors.request.use(config => {
    // 1. 从pinia获取token数据
    const userStore = useUserStore()
    // 2. 按照后端的要求拼接token数据
    const token = userStore.userInfo.token
    if (token) {
        config.headers.Authorization = `Bearer ${token}`
    }
    return config
}, e => Promise.reject(e))

// axios响应式拦截器
request.interceptors.response.use(
    res => res.data,
    e => {
        ElMessage({
            type: 'warning',
            message: e.response?.data?.message || 'An unexpected error occurred'
        });

        if (e.response?.status === 401) {
            const userStore = useUserStore();
            const router = useRouter();
            userStore.clearUserInfo();
            router.push('/login');
        }

        return Promise.reject(e);
    }
);



export default request